博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[译] 我最终是怎么玩转了 Vue 的作用域插槽
阅读量:7187 次
发布时间:2019-06-29

本文共 2672 字,大约阅读时间需要 8 分钟。

  • 原文地址:
  • 原文作者:
  • 译文出自:
  • 本文永久链接:
  • 译者:
  • 校对者:,

Vue 是一个用于构建 Web 应用程序的前端框架,其设计方式使得开发人员可以非常快速地提高工作效率。该框架的各个方面都有很多资料,它的社区也每天都在不断成长。如果你读到了这篇文章,那么这些事儿你很可能已经知道咯。

虽然我们可以快速直接地启动并运行它,但是框架里面那些更复杂和更强大的地方还是需要好好动动脑子才能理解(至少对我是这样)。其中一个是插槽,还有另一个与之相关但功能上不太相同的就是作用域插槽。我学习的时候花了好一阵才理解插槽工作的机制,所以我觉得将我对插槽的理解分享出来是有价值的,因为这没准会帮助到大家。

插槽和具名插槽

父组件以另外一种方式(不是通过常规的 Props 属性传递机制)向子组件传递信息。我发现把这种方法同常规的 HTML 元素联系起来很有帮助。

比如说 HTML 标签。

This is a link复制代码

如果这是在 Vue 环境中并且<a>是你的组件,那么你需要发送“This is a link”信息到‘a’组件里面,然后它将被渲染成为一个超链接,而“This is a link”就是这个链接的文本。

让我们定义一个子组件来展示它的机制是怎样的:

复制代码

然后在父组件我们这么做:

复制代码

这时候屏幕上呈现的就应该和你预期的一样就是“This is from outside”,但这是由子组件所渲染出来的。

我们还可以给子组件添加默认的信息,以免到时候这里出现什么都没有传入的情况,就像这样子:

复制代码

然后如果我们像这样子创建我们的子组件:

复制代码

我们可以看到屏幕上会呈现“Some default message”。

具名插槽和常规插槽非常类似,唯一的差别就是你可以在你的目标组件多个位置传入你的文本。

我们把子组件升级一下,让它有多个具名插槽

复制代码

这样,在我们的子组件中就有了三个插槽。其中 top 和 bottom 插槽是具名插槽。

让我们更新父组件以使用它。

Hello there!
复制代码

注意 —— 我们在这里使用新的 Vue 2.6 语法来指定我们想要定位的插槽:`v-slot:theName`。

你现在认为会在屏幕上看到什么呢?如果你说是“Hello Top!”,那么你就只说对了一部分。

因为我没有为没有具名的插槽赋予任何值,我们因此也还会得到默认值。所以我们真正会看到的是:

Some default message

Hello There!

其实真正意义上没有具名的插槽是被当作‘default’,所以你还可以这么做:

Hello There!
复制代码

现在我们就只会看到:

Hello There!

因为我们已经提供了值给默认(也就是未具名)插槽,因此具名插槽‘top’和‘bottom’也都没有默认值。

你发送的并不一定只是文本,还可以是其他组件或者 HTML。你可以发送任意你想展示的内容。

作用域插槽

我认为插槽和具名插槽相对简单,一旦你稍微玩玩就可以掌握。可另一方面,作用域插槽虽然名字相似但又有些不同之处。

我倾向于认为作用域插槽有点像一个放映机(或者是一个我欧洲朋友的投影仪)。以下是原因。

子组件中的作用域插槽可以为父组件中的插槽的显示提供数据。这就像一个人带着放映机站在你的子组件里面,然后在父组件的墙上让一些图像发光。

这有一个例子。在子组件中我们像这样设置了一个插槽:

复制代码

注意到我们的具名插槽‘top’现在有了一个名为‘myUser’的属性,然后我们绑定了一个动态的值在‘user’中。

在我们的父组件中就像这样子设置子组件:

{
{ slotProps }}
复制代码

我们在屏幕上看到的就是这样子:

{ “myUser”: “Ross” }

还是使用放映机的类比,我们的子组件通过 myUser 对象将其用户字符串的值传递给父组件。它在父组件上投射到的墙就被称为‘slotProps’。

我知道这不是一个完美的类比,但当我第一次尝试理解这个机制的时候,它帮助我以这种方式思考。

Vue 的文档非常好,而且我也已经看到了一些其他关于作用域插槽工作机制的说明。但很多人采取的方法似乎是将父组件中的所有或部分属性命名为与子组件相同,我认为这会使得数据很难被追踪。

在父组件中使用 ES6 解构,我们这样子写还可以将特定 user 对象从插槽属性(你可以随便怎么称呼它)解脱出来:

{
{ myUser }}
复制代码

或者甚至就只是在父组件中给它一个新的名字:

{
{ aFancyName }}
复制代码

所有都是通过 ES6 解构,与 Vue 本身并没有什么关系。

如果你正开始使用 Vue 和插槽,希望这可以让你起步并解决一些棘手的问题。

如果发现译文存在错误或其他需要改进的地方,欢迎到 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。


是一个翻译优质互联网技术文章的社区,文章来源为 上的英文分享文章。内容覆盖 、、、、、、、等领域,想要查看更多优质译文请持续关注 、、。

转载于:https://juejin.im/post/5c8856e6e51d456b30397f31

你可能感兴趣的文章
互联网时代还要不要读报纸杂志、看电视?
查看>>
Flash CS3 中改变组件的样式
查看>>
python中pickle使用学习-字典小程序函数化
查看>>
闲谈IPv6-现状和过渡
查看>>
libjpeg.so.62: no version information available (required
查看>>
maven deploy 的那些事
查看>>
跨平台即时通讯解决方案
查看>>
IT运维面临网络缓慢的解决方法
查看>>
linux系统日志解析
查看>>
[转]linq查询运算符大全
查看>>
DOMDocument::loadHTML(): htmlParseEntityRef: expecting ';' in Entity,
查看>>
软件项目的“管理之痒”
查看>>
硅谷课程 | 系统设计的基本方法SNAKE原则
查看>>
泰国取消国家数据中心建设计划
查看>>
富士通推新型RFID标签WT-A522L,适用于时尚服装和配件
查看>>
微软:10台Windows 10 PC已有8台已升一周年更新
查看>>
《UNIXLinux程序设计教程》一2.5 文件定位
查看>>
干货满满,阿里天池CIKM2017 Rank4比赛经验分享
查看>>
全闪存不是早买早亏
查看>>
成为更优秀的程序员:退后一步看问题
查看>>